package main.java.indi.zyj.coderecord;

public class MaxProfit3 {


    public int maxProfit(int k, int[] prices) {

        int len = prices.length;

        if (len == 0) {
            return 0;
        }

        // 第i天的状态为j，所剩下的最大现金是dp[i][j]
        // j的状态表示为：0 表示不操作, 1 第一次买入, 2 第一次卖出.......
        int[][] dp = new int[len][2 * k + 1];
        for (int i = 1; i < k * 2; i += 2) {
            dp[0][i] = -prices[0];
        }

        for (int i = 1; i < len; i++) {
            for (int j = 0; j < k * 2 - 1; j += 2) {
                dp[i][j + 1] = Math.max(dp[i - 1][j + 1], dp[i - 1][j] - prices[i]);
                dp[i][j + 2] = Math.max(dp[i - 1][j + 2], dp[i - 1][j + 1] + prices[i]);
            }
        }
        return dp[len - 1][k * 2];

    }



}
